# Assignment 2 :: Report

Organization of Digital Computers Lab EECS 112L University of California, Irvine 1 March 2019

> Team CTRL-C CTRL-V Aakif Hussain 63828630 Prannay Kapur 45621364

#### 1 Block Diagram



In the original block diagram, the RISC V processor implemented did not support any B type (branching), J type (jumping), or U type (unsigned) instructions. Our newly implemented design now features these instructions, and the following changes were made to support them:

- For the Immediate Generator, new outputs were included to support reading immediate values from B type, U type, and S type instructions.
- For the ALU, the actual instructions were implemented (e.g. AND = input\_1 & input\_2).
- For the Data Memory, the ability to load and store half words and bytes was implemented.
- For the Controller, new signal outputs were added to support the different types of U type instructions, the different types of J type instructions, and the B type instructions.
- For the Datapath, new multiplexers were added to support the new signals from the Controller and actually perform the jumps in the program counter given by the B type and J type instructions.

### 2 Module Simulation

#### 2.1 Screenshots of Waveform



#### 2.2 Complications

We faced multiple challenges when adding the new signals to the Datapath from the Controller. One such was an iteration error, because the program counter was not able to jump properly in accordance to what the instruction was asking. We faced some issues that were not solvable, such as the implementation of a JALR instruction, as for some reason, the 4-1 multiplexer was not able to assign data to the proper output.

## 3 Module Synthesis

#### 3.1 Power

```
Report : power
         -hier
        -analysis effort medium
        -verbose
Design : riscv
Version: J-2014.09-SP4
Date : Fri Mar 1 15:29:14 2019
Library(s) Used:
    saed321vt_tt1p05vn40c (File: /users/ugrad2/2012/spring/pooriam/libraries/saed321vt_tt1p0
Operating Conditions: tt1p05vn40c Library: saed32lvt_tt1p05vn40c
Wire Load Model Mode: enclosed
         Wire Load Model Library
             ForQA saed32lvt_tt1p05vn40c
ForQA saed32lvt_tt1p05vn40c
r ForQA saed32lvt_tt1p05vn40c
riscv
Controller
ALUController
Global Operating Voltage = 1.05
Power-specific unit information :
    Voltage Units = 1V
Capacitance Units = 1.000000ff
Time Units = 1ns
    Dynamic Power Units = 1uW
Leakage Power Units = 1pW
                                   (derived from V,C,T units)
             Switch Int Leak Total
Power Power Power %
Hierarchy
                             5.466 4.768 3.21e+07 42.305 100.0
1.875 1.798 1.63e+07 19.940 47.1
3.241 2.970 1.58e+07 22.015 52.0
  ac (ALUController)
  c (Controller)
```

#### 3.2 Area

\*\*\*\*\*\*

Report : area
Design : riscy
Version: J-2014.09-SP4
Date : Fri Mar 1 15:29:14 2019

Library(s) Used:

saed32lvt\_tt1p05vn40c (File: /users/ugrad2/2012/spring/pooriam/libraries/saed32lvt\_tt1p05vn40c.db)

Number of ports:
Number of nets:
Number of cells:
Number of combinational cells:
Number of sequential cells:
Number of macros/black boxes:
Number of buf/iny:
Number of references: Combinational area: 100.641025 Noncombinational area:
Noncombinational area:
Macro/Black Box area:
Net Interconnect area: 20.331520 0.000000 16.040373 100.641025 116.681397 Total cell area: Total area:

Information: This design contains black box (unknown) components. (RPT-8)

The above information was reported from the logical library. The following are from the physical library:

Hierarchical area distribution

|                   | Global cell area  |                  | Local cell area |                       |                 |               |
|-------------------|-------------------|------------------|-----------------|-----------------------|-----------------|---------------|
| Hierarchical cell | Absolute<br>Total | Percent<br>Total | -               | Noncombi-<br>national | Black-<br>boxes | Design        |
| riscv             | 100.6410          | 100.0            | 0.0000          | 0.0000                | 0.0000          | riscv         |
| ac                | 44.2211           | 43.9             | 44.2211         |                       |                 | ALUController |
| С                 | 56.4200           | 56.1             | 56.4200         | 0.0000                | 0.0000          | Controller    |
| Total             |                   |                  | 100.6410        | 0.0000                | 0.0000          |               |

## 3.3 Clock Frequency

| *******                                                                                                                                                                                                     | ******                                 |  |  |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------|--|--|
| port : gor                                                                                                                                                                                                  |                                        |  |  |
| esign : riscy                                                                                                                                                                                               |                                        |  |  |
| ersion: J-2014.09-SP4                                                                                                                                                                                       |                                        |  |  |
| te : Fri Mar 1 15:29:1                                                                                                                                                                                      | 4 2019                                 |  |  |
| **********                                                                                                                                                                                                  |                                        |  |  |
|                                                                                                                                                                                                             |                                        |  |  |
|                                                                                                                                                                                                             |                                        |  |  |
| Timing Path Group (none)                                                                                                                                                                                    |                                        |  |  |
|                                                                                                                                                                                                             |                                        |  |  |
| Levels of Logic: Critical Path Length: Critical Path Slack: Critical Path Clk Period: Total Negative Slack: No. of Violating Paths: Worst Hold Violation:                                                   | 1.00                                   |  |  |
| Critical Path Length:                                                                                                                                                                                       | 0.00                                   |  |  |
| Critical Path Slack:                                                                                                                                                                                        | uninit                                 |  |  |
| Critical Path Clk Period:                                                                                                                                                                                   | n/a                                    |  |  |
| Total Negative Slack:                                                                                                                                                                                       | 0.00                                   |  |  |
| No. of Violating Paths:                                                                                                                                                                                     | 0.00                                   |  |  |
| Worst Hold Violation:                                                                                                                                                                                       | 0.00                                   |  |  |
| Total Hold Violation:                                                                                                                                                                                       | 0.00                                   |  |  |
| Total Hold Violation:<br>No. of Hold Violations:                                                                                                                                                            | 0.00                                   |  |  |
|                                                                                                                                                                                                             |                                        |  |  |
| Hierarchical Cell Count: Hierarchical Port Count: Leaf Cell Count: Buf/Iny Cell Count: Buf Cell Count: Iny Cell Count: CT Buf/Iny Cell Count: Combinational Cell Count: Sequential Cell Count: Macro Count: | 36<br>57<br>16<br>0<br>16<br>0<br>57   |  |  |
| Area                                                                                                                                                                                                        |                                        |  |  |
|                                                                                                                                                                                                             | 100.641025                             |  |  |
| Combinational Area:                                                                                                                                                                                         | 0 000000                               |  |  |
| Noncombinational Area:                                                                                                                                                                                      | 0.000000                               |  |  |
| Noncombinational Area: Buf/Inv Area:                                                                                                                                                                        | 20.331520                              |  |  |
| Noncombinational Area: Buf/Inv Area: Total Buffer Area:                                                                                                                                                     | 20.331520                              |  |  |
| Noncombinational Area: Buf/Inv Area: Total Buffer Area: Total Inverter Area:                                                                                                                                | 20.331520<br>0.00<br>20.33             |  |  |
| Noncombinational Area: Buf/Inv Area: Total Buffer Area: Total Inverter Area:                                                                                                                                | 20.331520<br>0.00<br>20.33             |  |  |
| Noncombinational Area: Buf/Inv Area: Total Buffer Area:                                                                                                                                                     | 20.331520<br>0.00<br>20.33<br>0.000000 |  |  |